Memcached for .net
Memcached客户端.用的是memcacheddotnet_clientlib-1.1.5,其他的几款客户端原理都一样.
研究了一下源码,感觉memcacheddotnet表现还是很不错的.
MemCached还不支持缓存依赖..希望后续版本会增加这个功能.
[STAThread]
static void Main(string[] args)
{
//服务器端列表
string[] serverlist = { "127.0.0.1:11211" };
//初始化池
SockIOPool sock = SockIOPool.GetInstance();
sock.SetServers(serverlist);//添加服务器列表
sock.InitConnections = 3;//设置连接池初始数目
sock.MinConnections = 3;//设置最小连接数目
sock.MaxConnections = 5;//设置最大连接数目
sock.SocketConnectTimeout = 1000;//设置连接的套接字超时。
sock.SocketTimeout = 3000;//设置套接字超时读取
sock.MaintenanceSleep = 30;//设置维护线程运行的睡眠时间。如果设置为0,那么维护线程将不会启动;
//获取或设置池的故障标志。
//如果这个标志被设置为true则socket连接失败,
//将试图从另一台服务器返回一个套接字如果存在的话。
//如果设置为false,则得到一个套接字如果存在的话。否则返回NULL,如果它无法连接到请求的服务器。
sock.Failover = true;
//如果为false,对所有创建的套接字关闭Nagle的算法。
sock.Nagle = false;
sock.Initialize();
//获取客户端实例
MemcachedClient memcached = new MemcachedClient();
//是否启用压缩数据
memcached.EnableCompression = false;
Console.WriteLine("~~~~~~~~~~~~~~~~~~~~~~~~~~~Memcached Set");
//存储缓存数据。
//如果数据在服务器上不存在此键,或者如果键被删除指定的值将不被保存。
//到期时间到达时服务器会自动删除该键值.
//如果启用了压缩,数据压缩长于门槛的数据将被储存在压缩的形式。
//在当前版本中,所有对象会使用。NET序列化。
//参数说明:
//key:缓存的键.value:缓存对象. expiry:过期时间.hashCode:如果不为null,则诠释哈希码使用
//asString :作为字符串存储该对象
memcached.Set("test1", "test1");
Console.WriteLine(memcached.Get("test1"));
Console.WriteLine("~~~~~~~~~~~~~~~~~~~~~~~~~~~Memcached Add ,先Add再调用Set 相同键值Set会覆盖掉Add的值");
memcached.Add("test2", "value2");
Console.WriteLine(memcached.Get("test2"));
memcached.Set("test2", "value1 value2");
Console.WriteLine(memcached.Get("test2"));
Console.WriteLine("Memcached Replace ");
//在服务器上更新数据,指定键和值。
memcached.Replace("test2", "value3");
Console.WriteLine(memcached.Get("test2"));
Console.WriteLine("~~~~~~~~~~~~~~~~~~~~~~~~~~Memcached 键值是否存在");
if (memcached.KeyExists("test2"))
{
Console.WriteLine("键test2 存在");
}
Console.WriteLine("~~~~~~~~~~~~~~~~~~~~~~~~~~Memcached 删除数据");
memcached.Add("test4", "value4");
Console.WriteLine("test4==>" + memcached.Get("test4"));
memcached.Delete("test4");
if (!memcached.KeyExists("test4"))
{
Console.WriteLine("test4 已将删除");
}
Console.WriteLine("~~~~~~~~~~~~~~~~~~~~~~~Memcached 数据过期");
memcached.Add("test5", "value5", DateTime.Now.AddMilliseconds(5000));
Console.WriteLine(memcached.Get("test5"));
System.Threading.Thread.Sleep(6000);
Console.WriteLine("过期: " + memcached.Get("test5"));
Console.Read();
SockIOPool.GetInstance().Shutdown(); //关闭池, 关闭sockets
}
注释比较全,不做解释了..
(部分代码来源于网络)